Completed
Branch master (adfc9c)
by Rafael S.
04:01 queued 02:00
created

validation.js ➔ validateASCIICode   A

Complexity

Conditions 2
Paths 1

Size

Total Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 2
nc 1
nop 1
dl 0
loc 1
rs 10
c 0
b 0
f 0
1
/*
2
 * Copyright (c) 2017-2018 Rafael da Silva Rocha.
3
 *
4
 * Permission is hereby granted, free of charge, to any person obtaining
5
 * a copy of this software and associated documentation files (the
6
 * "Software"), to deal in the Software without restriction, including
7
 * without limitation the rights to use, copy, modify, merge, publish,
8
 * distribute, sublicense, and/or sell copies of the Software, and to
9
 * permit persons to whom the Software is furnished to do so, subject to
10
 * the following conditions:
11
 *
12
 * The above copyright notice and this permission notice shall be
13
 * included in all copies or substantial portions of the Software.
14
 *
15
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
16
 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
17
 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
18
 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
19
 * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
20
 * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
21
 * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
22
 *
23
 */
24
25
/**
26
 * @fileoverview Functions to validate input.
27
 * @see https://github.com/rochars/byte-data
28
 */
29
30
/**
31
 * Validate that the code is a valid ASCII code.
32
 * @param {number} code The code.
33
 * @throws {Error} If the code is not a valid ASCII code.
34
 */
35
export function validateASCIICode(code) {
36
  if (code > 127) {
37
    throw new Error ('Bad ASCII code.');
38
  }
39
}
40
41
/**
42
 * Validate that the value is not null or undefined.
43
 * @param {number} value The value.
44
 * @throws {Error} If the value is of type undefined.
45
 */
46
export function validateNotUndefined(value) {
47
  if (value === undefined) {
48
    throw new Error('Undefined value.');
49
  }
50
}
51
52
/**
53
 * Validate the type definition.
54
 * @param {!Object} theType The type definition.
55
 * @throws {Error} If the type definition is not valid.
56
 */
57
export function validateType(theType) {
58
  if (!theType) {
59
    throw new Error('Undefined type.');
60
  }
61
  if (theType.float) {
62
    validateFloatType_(theType);
63
  } else {
64
    validateIntType_(theType);
65
  }
66
}
67
68
/**
69
 * Validate the type definition of floating point numbers.
70
 * @param {!Object} theType The type definition.
71
 * @throws {Error} If the type definition is not valid.
72
 * @private
73
 */
74
function validateFloatType_(theType) {
75
  if ([16,32,64].indexOf(theType.bits) == -1) {
76
    throw new Error('Bad float type.');
77
  }
78
}
79
80
/**
81
 * Validate the type definition of integers.
82
 * @param {!Object} theType The type definition.
83
 * @throws {Error} If the type definition is not valid.
84
 * @private
85
 */
86
function validateIntType_(theType) {
87
  if (theType.bits < 1 || theType.bits > 53) {
88
    throw new Error('Bad type definition.');
89
  }
90
}
91